

# REGISTER ORGANIZATION OF INTEL® 8086 VS. INTEL® PENTIUM® 4 64-BIT

**NOTE:** This document contains information obtained from Intel® Architecture Manuals and various other sources in the internet. This information has been used here for educational purpose. No copyrights are meant to be violated.

By Subhajit Sahu (110EC0181)

Under the Guidance of Prof. Sarat Kumar Patra

Department of Electronics and Communication
National Institute of Technology, Rourkela

## Register Organization of Intel® 8086





| AX      | =             | Primary accumulator                               | ВХ         | =    | Base, accumulator |  |
|---------|---------------|---------------------------------------------------|------------|------|-------------------|--|
| CX      | =             | Counter, accumulator                              | DX         | =    | Data, accumulator |  |
|         |               |                                                   |            |      |                   |  |
| SI      | =             | Source Index                                      | DI         | =    | Destination Index |  |
| BP      | =             | Base Pointer                                      | SP         | =    | Stack Pointer     |  |
| IP      | =             | Instruction Pointer                               |            |      |                   |  |
|         |               |                                                   |            |      |                   |  |
| CS      | =             | Code Segment                                      | SS         | =    | Stack Segment     |  |
| DS      | =             | Data Segment                                      | ES         | =    | Extra Segment     |  |
|         |               |                                                   |            |      |                   |  |
| FLAGS   | =             | Status / Flag Register                            |            |      |                   |  |
|         |               |                                                   |            |      |                   |  |
|         |               |                                                   |            |      |                   |  |
| CS : IP | $\rightarrow$ | Memory address to next instruction to be executed |            |      |                   |  |
| CJ. IP  | /             | ivieniory address to next instruction to          | o ne exect | iteu |                   |  |

SS : SP → Memory address last data stored on stack

# Register Organization of Intel® Pentium® 4 64-bit



## **General Purpose Registers**







| RDX (64b) |           |                 |  |  |  |  |
|-----------|-----------|-----------------|--|--|--|--|
|           | EDX (32b) |                 |  |  |  |  |
|           |           | DX (16b)        |  |  |  |  |
|           |           | DH (8b) DL (8b) |  |  |  |  |

| Rx (64b) |           |           |  |  |  |  |
|----------|-----------|-----------|--|--|--|--|
|          | RxD (32b) |           |  |  |  |  |
|          |           | RxW (16b) |  |  |  |  |
|          |           | RxL(8b)   |  |  |  |  |



## **Index Registers**











## **Segment Registers**



## Status / Flag Register





## **FPU Registers**



### **MMX Registers**



## **XMM Registers**



#### **Register Organization of different Register Types**

#### **General Purpose Registers:**

These registers are used for arithmetic operations and temporary storage. BX / RBX / RCX can also be used for memory indexing for read/write.

#### **Index Registers:**

These registers are normally used for indexing memory for read/write. IP / RIP is a special register which stores the address of the next instruction to be executed.

#### Segment Registers:

These registers are used for segmentation operation in memory. These were very importantly used in 8086, but their usage is much reduced now due to flat memory concept, which is currently in use.

#### Flag Register:

This register stores the status of the last arithmetic operation, along with much more other boolean information, which indicate the state of the processor.

#### **FPU Registers:**

These are Floating Point Unit registers, used for performing floating-point arithmetic operations.

#### MMX Registers:

These are special purpose registers, used for Single Instruction – Multiple Data (SIMD) instructions which help improve processing speed for large volume data processing applications.

#### XMM Registers:

These are special purpose registers, used for Streaming SIMD instructions (SSE) which help improve processing speed for large volume data processing applications.

\_\_\_